<template>
  <el-dialog
    :v-model="showAdd"
    title="新增宿舍"
    width="30%"
    :close-on-click-modal="false"
  >
    <template v-slot:footer>
      <div class="dialog-footer">
        <el-button @click="handleClose">取消</el-button>
        <el-button type="primary" @click="handleSubmit">确定</el-button>
      </div>
    </template>

    <el-form :model="formData" ref="addDormForm" :rules="formRules" label-width="80px">
      <el-form-item label="宿舍号" prop="dormId">
        <el-input v-model="formData.dormId" placeholder="请输入宿舍号" style="width: 90%;"></el-input>
      </el-form-item>
      <el-form-item label="楼栋号" prop="building_num">
        <el-select v-model="formData.building_num" placeholder="请选择楼栋号" style="width: 90%;">
          <el-option
            :key="item._id"
            :label="item.text"
            :value="item.building_num"
            v-for="item in buildingOptions"
          />
        </el-select>
      </el-form-item>
    </el-form>
  </el-dialog>
</template>

<script>
export default {
  props: {
    visible: Boolean, // 控制弹窗显示与隐藏
  },
  data() {
    return {
      formData: {
        dormId: '',
        building_num: '',
        // 其他宿舍信息字段
      },
      formRules: {
        dormId: [{ required: true, message: '请输入宿舍号', trigger: 'blur' }],
        building_num: [{ required: true, message: '请选择楼栋号', trigger: 'change' }],
        // 其他宿舍信息的验证规则
      },
      buildingOptions: [], // 楼栋号的选项数据
    };
  },
  methods: {
    handleClose() {
      this.$refs.addDormForm.resetFields(); // 关闭时重置表单
      this.$emit('showAddDormEvent'); // 更新父组件中控制弹窗显示的属性
    },
    handleSubmit() {
      // 表单验证通过后的处理逻辑
      this.$refs.addDormForm.validate((valid) => {
        if (valid) {
          // 提交新增宿舍的逻辑，可以在这里发起异步请求等
          // 成功后关闭弹窗，可以触发父组件的更新操作
          this.$emit('update:visible', false);
          // 重置表单
          this.$refs.addDormForm.resetFields();
          // 触发父组件的更新数据操作
          this.$emit('update');
        }
      });
    },
  },
  watch: {
    visible(newVal) {
      if (!newVal) {
        // 当弹窗关闭时重置表单
        this.$refs.addDormForm.resetFields();
      }
    },
  },
};
</script>